<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://lf3-cdn-tos.bytecdntp.com/cdn/expire-1-M/vue/2.6.14/vue.js" type="application/javascript"></script>
</head>
<body>
  <div id="app">
    <!-- 在vue中如何获得dom元素??  推荐ref -->
    <img ref="imgRef" src="http://q6cu3t6jv.bkt.clouddn.com/1063705989926227968?t=1582797590950" @error="onError">
  </div>
</body>
<script>
  let vm = new Vue({
    el: '#app',
    // 在vue中什么时候得到dom元素??  在mounted之后
    mounted(){
    // 图片错误处理--方式1 --- 通过ref
    this.$refs.imgRef.onerror = function(){
      // 不可以使用箭头函数,箭头函数本身没有this,this是上一级的this.也就是mounted的this
      this.src="https://img01.yzcdn.cn/vant/cat.jpeg"
    }
   },
   methods: {
    // 方式2--->通过事件v-on/@
    onError(){
      // this.src='https://img01.yzcdn.cn/vant/cat.jpeg',  // 不可以methods里面的this指向的是vue实例
      this.$refs.imgRef.src='https://img01.yzcdn.cn/vant/cat.jpeg'
    }
   }
  })
</script>
</html>
